<!--
  ~ Licensed to the Apache Software Foundation (ASF) under one or more
  ~ contributor license agreements.  See the NOTICE file distributed with
  ~ this work for additional information regarding copyright ownership.
  ~ The ASF licenses this file to You under the Apache License, Version 2.0
  ~ (the "License"); you may not use this file except in compliance with
  ~ the License.  You may obtain a copy of the License at
  ~
  ~    http://www.apache.org/licenses/LICENSE-2.0
  ~
  ~ Unless required by applicable law or agreed to in writing, software
  ~ distributed under the License is distributed on an "AS IS" BASIS,
  ~ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  ~ See the License for the specific language governing permissions and
  ~ limitations under the License.
  ~
  -->
<sp-configuration-box title="Group by" marginTop="5px">
    <div header>
        <button
            mat-button
            mat-raised-button
            color="accent"
            class="small-button"
            style="margin-right: 10px"
            (click)="selectAllFields()"
        >
            Select all
        </button>
        <button
            mat-button
            mat-raised-button
            class="small-button mat-basic"
            style="margin-right: 10px"
            (click)="deselectAllFields()"
        >
            Deselect all
        </button>
    </div>
    <div fxLayout="column" class="field-scroll-panel">
        <div
            fxLayout="column"
            *ngFor="let groupByField of sourceConfig.queryConfig.groupBy"
        >
            <mat-checkbox
                [(ngModel)]="groupByField.selected"
                [attr.data-cy]="
                    'data-explorer-group-by-' + groupByField.runtimeName
                "
                (change)="triggerConfigurationUpdate()"
                color="accent"
            >
                {{ groupByField.runtimeName }}
            </mat-checkbox>
        </div>
    </div>
</sp-configuration-box>
